用過Spring Boot 的都知道在Spring Boot 中有以下兩種配置文件
-
bootstrap (.yml 或者.properties)
-
application (.yml 或者.properties)
為什麼會有這兩種配置文件呢?大家都清楚它們的區別和具體使用場景嗎?
bootstrap/ application 的區別
特意去翻了下Spring Boot 的官方文檔,沒有找到關於這兩種文件的具體定義,然後再翻了下Spring Cloud 的官方文檔找到了它們的區別。
http://cloud.spring.io/spring-cloud-static/Edgware.SR3/single/spring-cloud.html#thebootstrapapplicationcontext
認真閱讀了下文檔,原文大概意思是這樣。
Spring Cloud 構建於Spring Boot 之上,在Spring Boot 中有兩種上下文,一種是bootstrap, 另外一種是application, bootstrap 是應用程序的父上下文,也就是說bootstrap 加載優先於applicaton。bootstrap 主要用於從額外的資源來加載配置信息,還可以在本地外部配置文件中解密屬性。這兩個上下文共用一個環境,它是任何Spring應用程序的外部屬性的來源。bootstrap 裡面的屬性會優先加載,它們默認也不能被本地相同配置覆蓋。
因此,對比application 配置文件,bootstrap 配置文件具有以下幾個特性。
-
boostrap 由父ApplicationContext 加載,比applicaton 優先加載
-
boostrap 裡面的屬性不能被覆蓋
bootstrap/ application 的應用場景
application 配置文件這個容易理解,主要用於Spring Boot 項目的自動化配置。
bootstrap 配置文件有以下幾個應用場景。
-
使用Spring Cloud Config 配置中心時,這時需要在bootstrap 配置文件中添加連接到配置中心的配置屬性來加載外部配置中心的配置信息;
-
一些固定的不能被覆蓋的屬性
-
一些加密/解密的場景;
以下這個截圖是一個國外網友問了一個Spring Cloud 工程師得到的回答。
做過Spring Cloud 微服務的朋友應該對bootstrap 的應用十分清楚,我們也有Spring Cloud 的實戰教程,在Spring 專題中都能看到。